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AMENDMENTS TO THE CLAIMS 

1 . (currently amended) A method for reducing processor cycles required to send data over a 

communication link in packets having a packet size, the method comprising: 
sending a write cal L from an application running in a First context> comprising a first 

destination and pointing to a first quantity of data stored in vi rtual memorv destined for 
athe first destination and a second destination and pointing to a second q uantity of data 
stored in virtual memon- destined for the second destinanon, both the first ciiuinlitv of 
data and llie second quaniity of data greater than said packet size to a driver^ of a 
network interface controller, running in a second context through a socket; 
performing a zero-copy write translating the virtual memon' locations to a physical m e mor y 
location fbr from of saird- the first and second q imntitv quantities of data to said tho 
dBve fphvsical memor\' locations: and 
generatin g, bv the driver, a plurality of first packets less than or equal to sa^the packet size 
destined for tlie first destination from the first quantity of data and a plurality of second 
packets less than or equal to the packet size destined for the second destination from the 
second quantity of data, the first and second quantities of data located at the translated 
physical memorx' locations . 

2. (original) A method according to claim 1, further comprising grouping data firom a plurality of 

streams into said write call. 

3. (original) A method according to claim 2, wherein said grouped data comprises all data from 

said plurality of streams to be sent in a time interval. 

4. (original) A method according to claim 3, wherein the time interval is selected based on a bit 

rate of at least one stream. 

5. (currently amended) A method according to claim 1, wherein said zero cop>^ writo comprises 

wi-i-tiBg-data- the virtual memory^ comprisest e a translation buffe r, the driver having a 
translation mapping from the virtual memoiv of the translation buffer to physical memorv . 
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6. (currently amended) A method according to claim 5, wherein the zero-copy write comprises 

traiislatina the virtual memory location of the translation buffer to the physical memory 
location using the translation mapping of the drive r tronslation buflbr is setup with a 
tronGlation botwcon virtual niomors^ and physical momor^^ 

7. (original) A method according to claim 1, further comprising generating an interrupt only after 

a last packet of said plurality of packets is transmitted to said communication link. 

8. (original) A method according to claim 1, wherein said packet size is a maximum packet size 

allowable by the communication link. 

9. (original) A method according to claim 1, wherein the communication link comprises a 

network. 

10. (cancelled) 

1 1. (original) A method according to claim 1, wherein said quantity of data comprises at least a 
portion of a multimedia data file. 

12. (original) A method according to claim 1 1 wherein the multimedia data file requires real- 
time delivery. 

1 3. (original) A method according to claim 1 1, wherein the multimedia data file is a video file, 
an audio file, or a game file. 

14. (original) A method according to claim 1, wherein said quantity of data comprises at least a 
portion of a file having a format chosen from the group of formats consisting of MPEG-1, 
MPEG-2, MPEG-4, H.264, MPS, QuickTime, AVI, Audio/Video, real-time data in RTF 
format, and combinations thereof 
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15. (cancelled) 

16. (cancelled) 

17. (currently amended) A method according to claim 1, wherein said write call comprises a 
write vecto r with entries for the first destin^mon. the first data destined for the first 
destination, tlie second destination and the second data destined for the second destinaiion . 

18. (currently amended) A method according to claim 1, further comprising generating a single 
header comprising header information for a plurality of protocol layers and sending the 
single header to a queue for ft-the NIC. 

19. (currently amended) A computer program product for sending data over a communications 
link in packets having a packet size, the computer program product comprising; 

a computer-readable medium comprising a program module, the program module including 
instructions for: 

receiving a write call from an application running in a first context, comprising a first 
destination and pointing to a first quantity of data stored in viitual memory 
destined for the first destination and a second destination and pointing to a second 
quaiUiiv of data stored in virtual memor\' destined for the second destination, both 
the first quantity of data and the second quantity of data g reater than said packet 
size through a socke t the write call received at a driver running in a second 
context: 

performing a zero-copy write translating the virtual memor\' locations for the first and 
second quantities of data to physical memory^ locations o f said quantity of data : 
and 

generatin g, by tlie driver, a plurality of first packets less than or equal to seid-the 
packet size destined for the first destination from the first quantity of data and a 
plurality of second packets less than or equal to the nacket size destined for tlie 
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second destination from tlie second quantity of data, tlie first and second qua ntitie s 
of data located at the translated physical memory locations . 

20. (original) A computer program product according to claim 19, further comprising 
instructions for: grouping data from a plurality of streams into said write call. 

2 1 . (original) A computer program product according to claim 20, wherein said grouped data 
comprises all data from said plurality of streams to be sent in a time interval. 

22. (original) A computer program product according to claim 21, wherein the time interval is 
selected based on a bit rate of at least one stream. 

1 

23. (currently amended) A computer program product according to claim 19, wherein said y^cro 
copy write comprises writing data t he virtual memory- comprisest e a translation buffe r, the 
driver having a translation mapping from the virtual memory^ of the translation buffer to 
physical memory^ 

24. (currently amended) A computer program product according to claim 23, wherein the zero- 
copy write comprises translating the virtual menioA localion of the translation buffer to the 
physical memorx' location using the translation mapping of the drive r tronslnuon buffer is 
s e tup with a translation betw ee n v i rtual momor)' and phy s ical momonv . 

25. (original) A computer program product according to claim 19, further comprising generating 
an interrupt only after a last packet of said plurality of packets is transmitted to said 
communication link. 

26. (original) A computer program product according to claim 19, wherein said packet size is a 
maximum packet size allowable by the communication link. 

27. (cancelled) 
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28. (original) A computer program product according to claim 19, wherein said quantity of data 
comprises at least a portion of a multimedia data file. 

29. (original) A computer program product according to claim 28 wherein the multimedia data 
file requires real-time delivery. 

30. (original) A computer program product according to claim. 28, wherein the multimedia data 
file is a video file, an audio file, or a game file. 

3 1. (original) A computer program product according to claim 19, wherein said quantity of data 
comprises at least a portion of a file having a format chosen from the group of formats 
consisting of N4PEG-1, MPEG-2, MPEG-4, H.264, MPS, QuickTime, AVI, Audio/Video, 
real-time data in RTF format, and combinations thereof. 

32. (cancelled) 

33. (cancelled) 

34. (currently amended) A computer program product according to claim 19, wherein said write 
call comprises a write vecto r witli entries for tlie first destination, the first data destined for 
the first destinatioii. the second destination and tlie second data destined for the second 
destination . 

35. (currently amended) A method for reducing buffering requirements on a network switch; the 
method comprising: 

receiving a write call from an application running in a firs! context through a socket, the 
write call comprising a plurality of destinations, including a first destination and a 
second destination, and pointing to a first quantity of data destined for the first 
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destination, and poin ti ng to a second quantity of data destined for the second destination^ 

the write call received at a driver ninning a second context : 
packetizing said first quantity of data into a plurality of packets less than or equal to a packet 

size, each packet destined for the first destination; 
generating at least one packet comprising at least a portion of the second quantity of data 

destined for the second destination; 
transmitting a first packet destined for the first destination to the network switch; and 
transmitting llie at least one packet destined for the second destination to the network switch, 

before transmitting a second packet destmed for the first destination. 

36. (original) A method according to claim 35, wherein the first quantity of data comprises at 
least a portion of a video media file. 

37. (original) A method according to claim 35, 

further comprising generating a plurality of said packets comprising at least a portion of the 
second quantity of data destined for the second destination. 

38. (original) A method according to claim 35, further comprising: 
transmitting the second packet destined for the first destination. 

39. (cancelled) 

40. (original) A method according to claim 35, further comprising: communicating at least one of 
said packets to a network interface card. 

41. (currently amended) A method according to claim 35, w^ierein the write call points to the 
first and second quantity of data stored in virtual memor\^ and f urther comprising: performing 
a zero-copy write translating tlie vittual memory^ locations for the first and second quantities 
of data to physical memor\- locations e fH5atd-<-wanfrtN^4at^. 
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42. (original) A method according to claim 35, wherein said write call comprises a write vector. 

43. (currently amended) A computer program product for balancing load on a network switch, 
the computer program product comprising: 

a computer-readable medium comprising a program module, the program module including 
instructions for: 

receiving a write call from an application running in a First context through a socket, 
the write call comprising a plurality of destinations, including a first destination 
and a second destination, and pointing to a first quantity of data destined for the 
first destination, and pointing a second quantity of data destined for the second 
destination , the write call received at a driver running in a second context : 

packetizing said first quantity of data into a plurality of packets less than or equal to a 
packet size, each packet destined for the first destination; 

generating at least one packet comprising at least a portion of the second quantity of 
data destined for the second destination; 

transmitting a first packet destined for the first destination to the network switch; and 

transmitting the at least one packet destined for the second destination to the network 
switch, before transmitting a second packet destined for the first destination. 

44. (currently amended) A system for sending data across a network, the system comprising: 
a computer running an application in a fust context configured to send a write call to a 

driver running in a second context through a socket, the write call comprising a first 
destination and pointing to a first quantity of data stored in virtual memory destined for 
tlie first ^ destination and a second destination and pointing to a second quantity of data 
stored in virtual niemorx^ destined for the second destination, both the first qimntitv of 
data and the second quantity of data g reater than said packet size to a driver, of a 
network interface controller, running in a second context , the application further 
configured to perform a zero-copy write to translate tlie virtual niemotv locations for the 
first and second quantities of data to physical memory^ locationse :(^ai4-<^uan#t\''"^(^dato 
to said driver ; 
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the driver configured to uenerale a plurality of first packets less than or equal to the packet 
size destined for the first destination From the first quantity of data and a pluraliK^ of 
second packets less than or equal to tlie packet si/e destined for the second destination 
From the second quantity of data, tlie first and second quantities of data located at tlie 
translated physical memory^ location s paokotize said data into a plurality of packets less 
tlian or equal to said packet size ; and 

a downstream device adapted to receive at least one of said packets. 

45. (original) A system according to claim 44, further comprising a network switch coupled to 
the computer and the downstream device, adapted to receive at least one of said packets and 
route the received packet to the downstream device. 

46. (original) A system according to claim 44, wherein the downstream device comprises a down 
stream device has a timing requirement for receipt of data 

47. (original) A system according to claim 45, further comprising a plurality of said computers in 
communication with the network switch. 

48. (original) A system according to claim 44, further comprising a plurality of downstream 
devices in communication with the network switch. 



Page 11 of 14 



